#### **Instruction Formats**

Muhammad Afzaal m.afzaal@nu.edu.pk

## **Book Chapter**

- "Computer Organization and Architecture"
- Author "William Stallings"
- 8<sup>th</sup> Edition
- Chapter 11
  - Section 11.3

# **Instruction Format (1/2)**

- Defines the layout of the bits in an instruction
  - Operation Code (opcode)
    - Necessary instruction element
    - Tells the CPU what to do
  - Source/destination Operands
    - An instruction can have zero or more operands
    - Operands are referenced using one the addressing modes
- Basic design issues in Instruction Format are
  - Instruction Length
  - Allocation of bits

# **Instruction Format (2/2)**

Simple Instruction Format example



## **Instruction Length**

- Instruction Length affects and is affected by
  - Memory size
  - Memory organization
  - Bus structure
  - Processor complexity
  - Processor speed
- Trade off between powerful instruction repertoire and saving space

#### **Allocation of Bits**

- More operations in an instruction set requires more opcodes
- More opcodes means more bits in opcode field and less bits in operand references
- Following factors help to determine the use of addressing bits
  - Number of addressing modes
  - Number of operands
  - Register versus Memory
  - Number of register sets
  - Address range
  - Address granularity

### PDP-8 Instruction Format (1/2)

#### Memory Reference Instructions

| opcode |   | D/I | Z/C |   | Displacement |    |
|--------|---|-----|-----|---|--------------|----|
| 0      | 2 | 3   | 4   | 5 |              | 11 |

#### Input/Output Instructions

| 1 | 1 | 0 |   | Device |   | ор | code |
|---|---|---|---|--------|---|----|------|
| 0 |   | 2 | 3 |        | 8 | 9  | 11   |

D/I = Diret/Indirect Address Z/C = Page 0 or Current page

### PDP-8 Instruction Format (2/2)

#### Register Reference Instructions

| 1 | 1 | 1 | 0 | CLA | CLL | CMA | CML | RAR | RAL | BSW | IAC |
|---|---|---|---|-----|-----|-----|-----|-----|-----|-----|-----|
| 0 | 1 | 2 | 3 | 4   | 5   | 6   | 7   | 8   | 9   | 10  | 11  |
| 1 | 1 | 1 | 0 | CLA | SMA | SZA | SNL | RSS | OSR | HLT | 0   |
| 0 | 1 | 2 | 3 | 4   | 5   | 6   | 7   | 8   | 9   | 10  | 11  |
| 1 | 1 | 1 | 0 | CLA | MQA | 0   | MQL | 0   | 0   | 0   | 1   |
| 0 |   |   |   |     |     |     |     |     |     |     |     |

CLA = Clear Accumulator

CLL = Clear Link

CMA= CoMplement Accumulator

CML= CoMplement Link

RAR= Rotate Accumulator Right

RAL= Rotate Accumulator Left

BSW= Byte SWap

IAC = Increment ACcumulator

SMA= Skip on Minus Accumulator

SZA= Skip on Zero Accumulator

SNL= Skip on Nonzero Link

RSS= Reverse Skip Sense

OSR= Or with Switch Register

HLT= HaLT

MQA=Multiplier Quotient into Accumulator

MQL=Multiplier Quotient Load

#### **PDP-10 Instruction Format**

|   | Opcode | Register | 1 | Ind<br>Regi | ex<br>ster | Memory Address |    |
|---|--------|----------|---|-------------|------------|----------------|----|
| 0 | 8      | 9 12     |   | 14          | 17         | 18             | 35 |

I = Indirect Bit

## PDP-11 Instruction Format (1/3)

#### 16-bit instruction formats

| Opcode | Source       | Destin | Destination |  | Opcode | R  | 9  | Source    |
|--------|--------------|--------|-------------|--|--------|----|----|-----------|
| 4      | 6            | 6      | 6           |  | 7      | 3  |    | 6         |
| Орс    | Opcode Offse |        |             |  | Opcode | FP | De | stination |
| 8      | 8            |        | 8           |  | 8      | 2  |    | 6         |
| Opcode |              | Destin | Destination |  | Opcod  | e  |    | CC        |
|        | 10 6         |        | <b>,</b>    |  | 12     |    |    | 4         |
| Opcode |              |        | R           |  | Opcode |    |    |           |
| 13     |              |        | 3           |  |        | 16 |    |           |

Source and Destination each contain a 3-bit addressing mode and 3-bit register number

FP indicates one of four floating point registers R indicates one of the general-purpose registers CC is the condition code field

# PDP-11 Instruction Format (2/3)

#### 32-bit instruction formats

| Opcode | Sou       | rce         | Destination    | Memory Address |
|--------|-----------|-------------|----------------|----------------|
| 4      | 6         |             | 6              | 16             |
| Opco   | Opcode R  |             | Source         | Memory Address |
| 7      | 7 3       |             | 6              | 16             |
| Орс    | Opcode FI |             | Destination    | Memory Address |
| 8      | 8 2       |             | 6              | 16             |
| Opcode |           | Destination | Memory Address |                |
|        | 10 6      |             | 6              | 16             |

# PDP-11 Instruction Format (3/3)

48-bit instruction formats

| Opcode | Source | Destination | Memory Address1 | Memory Address2 |
|--------|--------|-------------|-----------------|-----------------|
| 4      | 6      | 6           | 16              | 16              |